<?php

use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;

class CreatePledgeDdu extends Migration
{
    /**
     * Run the migrations.
     */
    public function up(): void
    {
        Schema::create('pledge_ddu', function (Blueprint $table) {
            $table->id()->from(config('migration.from'));

            $table->string('number')->nullable()->comment('Номер');
            $table->date('date')->nullable()->comment('Дата');
            $table->string('developer')->nullable()->comment('Застройщик');

            $table->string('ogrn_developer')->nullable()->comment('ОГРН (Застройщик)');

            $table->string('registration_region')->nullable()->comment('Регион регистрации права участника долевого строительства');
            $table->string('registration_number')->nullable()->comment('Номер регистрации права участника долевого строительства');

            $table->string('sum')->nullable()->comment('Уплаченная сумма застройщику');
            $table->text('address')->nullable()->comment('Адрес');

            $table->enum('total_area_type', ['meter', 'ga'])->default('meter')->comment('Тип площади');
            $table->string('total_area')->nullable()->comment('Общая проектная площадь');

            $table->string('floor')->nullable()->comment('Этаж');
            $table->string('floors_number')->nullable()->comment('Общая этажность здания');
            $table->string('conditional_number')->nullable()->comment('Условный номер жилого помещения');

            $table->jsonb('plans')->default(json_encode([]))->comment('Технический план');
            $table->index('plans', null, 'gin');

            $table->date('transfer_date')->nullable()->comment('Срок передачи жилого помещения Застройщиком');

            $table->text('other_information')->nullable()->comment('Иные сведения');

            $table->jsonb('documents')->default(json_encode([]))->comment('Иные документы');
            $table->index('documents', null, 'gin');
        });
    }

    /**
     * Reverse the migrations.
     */
    public function down(): void
    {
        Schema::dropIfExists('pledge_ddu');
    }
}
